package com.ruoyi.statistic.mapper;


import com.ruoyi.statistic.domain.StatisticStudentEmploymentFile;
import com.ruoyi.statistic.domain.vo.StatisticStudentEmploymentFileSearchVo;
import org.apache.ibatis.annotations.Param;

import java.util.Date;
import java.util.List;

/**
 * 学生就业数据文件管理Mapper接口
 *
 * @author linyang
 * @date 2023-02-15
 */
public interface StatisticStudentEmploymentFileMapper {

    /**
     * 查询学生就业数据文件管理
     *
     * @param id 学生就业数据文件管理主键
     * @return 学生就业数据文件管理
     */
    public StatisticStudentEmploymentFile selectStatisticStudentEmploymentFileById(@Param("id") Long id);


    /**
     * 判断是否存在指定日期的文件
     *
     * @param date
     * @return
     */
    public StatisticStudentEmploymentFile selectStatisticStudentEmploymentFileByDate(@Param("year") String year, @Param("date") Date date);

    /**
     * 查询学生就业数据文件管理列表
     *
     * @param vo
     * @return
     */
    public List<StatisticStudentEmploymentFile> selectStatisticStudentEmploymentFileList(StatisticStudentEmploymentFileSearchVo vo);

    /**
     * 新增学生就业数据文件管理
     *
     * @param studentEmploymentFile 学生就业数据文件管理
     * @return 结果
     */
    public int insertStatisticStudentEmploymentFile(StatisticStudentEmploymentFile studentEmploymentFile);

    /**
     * 修改学生就业数据文件管理
     *
     * @param studentEmploymentFile 学生就业数据文件管理
     * @return 结果
     */
    public int updateStatisticStudentEmploymentFile(StatisticStudentEmploymentFile studentEmploymentFile);

    /**
     * 删除学生就业数据文件管理
     *
     * @param id 学生就业数据文件管理主键
     * @return 结果
     */
    public int deleteStatisticStudentEmploymentFileById(@Param("id") Long id);

    /**
     * 删除学生就业数据文件管理信息
     *
     * @param date
     * @return
     */
    public int deleteStatisticStudentEmploymentFileByDate(@Param("year") String year, @Param("date") Date date);

    /**
     * 批量删除学生就业数据文件管理
     *
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteStatisticStudentEmploymentFileByIds(@Param("ids") Long[] ids);


    /**
     * 获取最后一次文件上传日期
     *
     * @return
     */
    public Date selectLastFileDate(@Param("year") String year);


    /**
     * 获取近N天的文件数据
     *
     * @param year
     * @param days
     * @return
     */
    public List<StatisticStudentEmploymentFile> selectRecentDaysFile(@Param("year") String year, @Param("days") Integer days);


    /**
     * 获取当前年份最新数据的日期
     * @param year
     * @return
     */
    public Date selectMaxDateByYear(String year);
}
